

**WHAT IS CLAIMED IS:**

1        1. In an integrated circuit multiprocessor switching device, an apparatus for  
2 mapping a plurality of interrupt sources from a plurality of data channels to a plurality of  
3 processors, comprising:

4            a first interrupt status register for storing at least one interrupt source for a first  
5 data channel;

6            a second interrupt status register for storing at least one interrupt source for a  
7 second data channel;

8            an interrupt indication register associated with each data channel for storing a  
9 merged interrupt value representing said at least one interrupt source for the associated  
10 data channel, where each interrupt indication register is combined to form a merged  
11 interrupt status register;

12            an interrupt mapping register associated with each data channel for storing a  
13 processor identification for each associated data channel;

14            for each data channel, a demultiplexing circuit coupled to the merged interrupt  
15 status register and the interrupt mapping register associated with the data channel for  
16 coupling the merged interrupt value for the each data channel to a processor identified by  
17 the processor identification.

1        2. The apparatus recited in claim 1 formed in a packet manager input circuit  
2 for mapping a plurality of interrupt sources from a plurality of input channels such that  
3 the first data channel comprises a first input channel and the second data channel  
4 comprises a second input channel.

1        3. The apparatus recited in claim 1 formed in a packet manager output circuit  
2 wherein the first data channel comprises a first output virtual channel and the second data  
3 channel comprises a second output virtual channel.

1        4. The apparatus recited in claim 1 formed in a system controller wherein the  
2 plurality of data channels comprises at least one input channel having a first plurality of  
3 interrupt sources and at least one output channel having a second plurality of interrupt

4       sources and wherein the merged interrupt status register comprises a first interrupt  
5       indication register associated with said at least one input channel for storing a merged  
6       interrupt value representing the first plurality of interrupt sources and a second interrupt  
7       indication register associated with said at least one output channel for storing a merged  
8       interrupt value representing the second plurality of interrupt sources.

1           5.       The apparatus recited in claim 1, further comprising a first mask register  
2       for selectively masking the at least one interrupt source for the first data channel, wherein  
3       the merged interrupt value comprises a masked merged interrupt value.

1           6.       The apparatus recited in claim 5 wherein the first mask register is  
2       programmable to select which interrupt source is masked.

1           7.       The apparatus recited in claim 1, wherein the processor identified by the  
2       processor identification determines an interrupting channel by running an interrupt  
3       service routine that first reads the merged interrupt status register to identify which data  
4       channel generated the interrupt and then reads the interrupt status register corresponding  
5       to the identified data channel to determine the interrupt source for the interrupting  
6       channel.

1           8.       The apparatus recited in claim 1, wherein each interrupt mapping register  
2       further comprises a priority level indication associated with each data channel for  
3       prioritizing any interrupt issued by the data channel, whereby the demultiplexing circuit  
4       selectively couples the merged interrupt value for the each data channel to a plurality of  
5       prioritized processor interrupt signals under control of the processor identification and  
6       priority level indication.

1           9.       An interrupt mapper for mapping interrupts from a plurality of channels to  
2       a plurality of processing cores, comprising:  
3                a plurality of source registers, where each source register identifies interrupt  
4       sources for one of the plurality of channels;

5           a mask register associated with each of the plurality of source registers for  
6   selectively masking said associated source register to generate masked interrupt sources  
7   for each channel;

8           a channel merge circuit for merging the masked interrupt sources for each channel  
9   into an interrupt indication value for said channel;

10          a channel register that stores the interrupt indication values for the plurality of  
11   channels;

12          a plurality of processor map storage devices, each processor map storage device  
13   storing a processor identification value for one of the plurality of channels; and

14          a demultiplexer coupled to the channel register and the plurality of processor map  
15   storage devices for mapping each interrupt indication value for a channel to a processing  
16   core identified by the processor identification for that channel.

1           10.       The interrupt mapper as recited in claim 9, further comprising a plurality  
2   of AND gates coupled to the source registers and mask registers for generating the  
3   masked interrupt sources for each channel.

1           11.       The interrupt mapper as recited in claim 9, wherein each processor map  
2   storage device stores a processor identification value and a priority level for one of the  
3   plurality of channels.

1           12.       The interrupt mapper as recited in claim 9, wherein the channel merge  
2   circuit comprises OR gate circuitry for merging the masked interrupt sources into an  
3   interrupt indication value for each channel.

1           13.       The interrupt mapper as recited in claim 9, wherein a processing core that  
2   receives an interrupt reads the channel register to determine which channel generated the  
3   interrupt and then reads the plurality of source registers to determine a source for the  
4   channel's interrupt.

1           14.       The interrupt mapper as recited in claim 13, wherein the plurality of  
2   source registers and the channel register are each sized to match a processing width of the  
3   processing core.

1           15.    The interrupt mapper as recited in claim 14, wherein the processing core  
2 determines the source of an interrupt with two register reads.

1           16.    The interrupt mapper as recited in claim 9, wherein interrupts from each  
2 channel are mapped to only one processing core.

1           17.    The interrupt mapper as recited in claim 9, wherein the plurality of  
2 processor map storage devices are programmable to dynamically assign channel  
3 interrupts to the processing cores to implement load balancing among the processing  
4 cores.

1           18.    A method for processing interrupts from a plurality of channels to a  
2 plurality of processing cores in an integrated circuit multiprocessor, comprising:  
3            receiving a mapped interrupt signal at a first processor core;  
4            reading a merged interrupt status register to identify an issuing channel from the  
5 plurality of channels that issued the mapped interrupt signal;  
6            reading an interrupt source register for the issuing channel to determine an  
7 interrupt source; and  
8            processing the interrupt source specified in the interrupt source register for the  
9 issuing channel.

1           19.    The method of claim 18, further comprising reading a single status  
2 register containing interrupt sources for a plurality of active channels to identify the  
3 interrupt source when all possible interrupt sources from the plurality of active channels  
4 can be stored in the single status register.

1           20.    The method of claim 18, further comprising:  
2            masking a plurality of interrupt sources for each channel;  
3            for each channel, merging the masked plurality of interrupt sources to an interrupt  
4 indication value;  
5            storing the interrupt indication value for each channel in the merged interrupt  
6 status register;

7            mapping the interrupt indication value for each channel to the mapped interrupt  
8    signal under control of a processor identification value assigned to each channel.